package com.qianfeng.servletcontext.filters;


//
//                            _ooOoo_  
//                           o8888888o  
//                           88" . "88  
//                           (| -_- |)  
//                            O\ = /O  
//                        ____/`---'\____  
//                      .   ' \\| |// `.  
//                       / \\||| : |||// \  
//                     / _||||| -:- |||||- \  
//                       | | \\\ - /// | |  
//                     | \_| ''\---/'' | |  
//                      \ .-\__ `-` ___/-. /  
//                   ___`. .' /--.--\ `. . __  
//                ."" '< `.___\_<|>_/___.' >'"".  
//               | | : `- \`.;`\ _ /`;.`/ - ` : | |  
//                 \ \ `-. \_ __\ /__ _/ .-` / /  
//         ======`-.____`-.___\_____/___.-`____.-'======  
//                            `=---='  
//  
//         .............................................  
//                  佛祖镇楼            BUG辟易  
//          佛曰:  
//                  写字楼里写字间，写字间里程序员；  
//                  程序人员写程序，又拿程序换酒钱。  
//                  酒醒只在网上坐，酒醉还来网下眠；  
//                  酒醉酒醒日复日，网上网下年复年。  
//                  但愿老死电脑间，不愿鞠躬老板前；  
//                  奔驰宝马贵者趣，公交自行程序员。  
//                  别人笑我忒疯癫，我笑自己命太贱；  


import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * Created by jackiechan on 2021/8/30 10:30
 *
 * @author jackiechan
 * @version 1.0
 * @since 1.0
 */

public class LoginFilter implements Filter {

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.err.println("登录过滤器执行了");
        //首先我们发现我们这个过滤器可以执行,但是我们发现我们重定向的那个地址也是需要登录才可以访问的
        //也就是说我们现在这个过滤器拦截的是所有的地址,把不该拦截的也拦截了
        //要么就修改拦截器的拦截地址,另外一个方式就是拦截所有地址,但是在代码中进行判断,把不拦截的直接放行
        StringBuffer requestURL = ((HttpServletRequest) servletRequest).getRequestURL();
        System.err.println(requestURL);
        if (requestURL.toString().contains("index.html") || requestURL.toString().contains("login")) {//我们发现 index.html 是不需要拦截,直接放行
            filterChain.doFilter(servletRequest, servletResponse);//放行
            return;
        }

        Object user = ((HttpServletRequest) servletRequest).getSession().getAttribute("user");
        if (user == null) {
            System.err.println("没有登录,请登录");
            ((HttpServletResponse) servletResponse).sendRedirect("/index.html");
            return;
        }

        filterChain.doFilter(servletRequest, servletResponse);//放行

    }
}
